Coverage Report

Created: 2024-12-26 12:25

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
D:\a\tools.proto\tools.proto\compiler\src\gen\base\message_from_bytes.rs
Line
Count
Source
1
// Copyright (c) 2024, BlockProject 3D
2
//
3
// All rights reserved.
4
//
5
// Redistribution and use in source and binary forms, with or without modification,
6
// are permitted provided that the following conditions are met:
7
//
8
//     * Redistributions of source code must retain the above copyright notice,
9
//       this list of conditions and the following disclaimer.
10
//     * Redistributions in binary form must reproduce the above copyright notice,
11
//       this list of conditions and the following disclaimer in the documentation
12
//       and/or other materials provided with the distribution.
13
//     * Neither the name of BlockProject 3D nor the names of its contributors
14
//       may be used to endorse or promote products derived from this software
15
//       without specific prior written permission.
16
//
17
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
21
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
29
use crate::compiler::message::{Field, Message};
30
use crate::compiler::util::types::TypeMapper;
31
use crate::gen::base::map::TypePathMapper;
32
use crate::gen::base::message::{Templates, Utilities};
33
use crate::gen::base::message_common::generate_field_type_inline;
34
use crate::gen::base::Error;
35
use itertools::Itertools;
36
37
63
fn gen_field_from_bytes_impl<U: Utilities, T: TypeMapper>(
38
63
    field: &Field,
39
63
    templates: &Templates,
40
63
    type_path_map: &TypePathMapper<T>,
41
63
    function: &str,
42
63
) -> Result<String, Error> {
43
63
    let mut scope = templates.template.scope();
44
63
    scope.var("name", &field.name);
45
63
    let codec_template = templates.get(field.codec())
?0
;
46
63
    let msg_type = generate_field_type_inline::<U, T>(field, codec_template, type_path_map, "from_bytes")
?0
;
47
63
    if let Some(
header8
) = &field.header {
  Branch (47:12): [True: 8, False: 55]
  Branch (47:12): [True: 0, False: 0]
  Branch (47:12): [Folded - Ignored]
48
8
        scope.var("header_name", &header.name);
49
55
    }
50
63
    scope.var("type", msg_type);
51
63
    if field.header.is_some() && 
field.ty.is_union()8
{
  Branch (51:8): [True: 8, False: 55]
  Branch (51:34): [True: 4, False: 4]
  Branch (51:8): [True: 0, False: 0]
  Branch (51:34): [True: 0, False: 0]
  Branch (51:8): [Folded - Ignored]
  Branch (51:34): [Folded - Ignored]
52
4
        Ok(scope.render(function, &["field_union"]).unwrap())
53
59
    } else if field.header.is_some() {
  Branch (53:15): [True: 4, False: 55]
  Branch (53:15): [True: 0, False: 0]
  Branch (53:15): [Folded - Ignored]
54
4
        Ok(scope.render(function, &["field_header"]).unwrap())
55
55
    } else if field.ty.is_message_reference() {
  Branch (55:15): [True: 4, False: 51]
  Branch (55:15): [True: 0, False: 0]
  Branch (55:15): [Folded - Ignored]
56
4
        Ok(scope.render(function, &["field_msg"]).unwrap())
57
    } else {
58
51
        Ok(scope.render(function, &["field"]).unwrap())
59
    }
60
63
}
61
62
33
pub fn generate_from_bytes_impl<U: Utilities, T: TypeMapper>(
63
33
    msg: &Message,
64
33
    templates: &Templates,
65
33
    type_path_map: &TypePathMapper<T>,
66
33
    function: &str,
67
33
) -> Result<String, Error> {
68
33
    let fields = msg
69
33
        .fields
70
33
        .iter()
71
63
        .map(|field| gen_field_from_bytes_impl::<U, T>(field, templates, type_path_map, function))
72
33
        .collect::<Result<Vec<String>, Error>>()
?0
73
33
        .join("");
74
33
    let field_names = msg
75
33
        .fields
76
33
        .iter()
77
63
        .map(|field| templates.template.scope().var("name", &field.name).render(function, &["field_name"]).unwrap())
78
33
        .join("");
79
33
    Ok(templates
80
33
        .template
81
33
        .scope()
82
33
        .var("fields", fields)
83
33
        .var("field_names", field_names)
84
33
        .render("", &[function])
85
33
        .unwrap())
86
33
}
87
88
31
pub fn generate<'variable, U: Utilities, T: TypeMapper>(
89
31
    mut templates: Templates<'_, 'variable>,
90
31
    msg: &'variable Message,
91
31
    type_path_map: &TypePathMapper<T>,
92
31
    function: &str,
93
31
) -> Result<String, Error> {
94
31
    templates.template.var("msg_name", &msg.name);
95
31
    generate_from_bytes_impl::<U, T>(msg, &templates, type_path_map, function)
96
31
}